package com.myth.callable;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;

/**
 * 创建线程的方式四:使用线程池
 *
 * 好处:
 * 1.提高响应速度（减少了创建新线程的时间)
 * 2.降低资源消耗（重复利用线程池中线程，不需要每次都创建）
 * 3.便于线程管理
 *      corePoolSize:核心池的大小
 *      maximumPoolSize:最大线程数
 *      keepAliveTime:线程没有任务时最多保持多长时间后会终止
 *
 *
 * @author
 * @create 2021/8/10
 */
public class 多线程 {
    public static void main(String[] args) {
        //1．提供指定线程数量的线程池
        ExecutorService service = Executors.newFixedThreadPool(10);
        ThreadPoolExecutor service1 = (ThreadPoolExecutor) service;

        //设置线程池的属性
        service1.setCorePoolSize(15);


        //2.执行指定的线程的操作。需要提供实现Runnable接口或callable接口实现类的对象
        service.execute(new 模板());//适合适用于Runnable
//        service.submit();//适合适用于Callable

        //3.关闭线程池
        service.shutdown();
    }
}

class 模板 implements Runnable{

    @Override
    public void run() {
        for (int i = 0; i <= 100; i++) {
            if (i % 2 ==0) {
                System.out.println(Thread.currentThread().getName()+":"+i);
            }
        }

    }
}
